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INTERFACE, STRUCTURE AND METHOD FOR 
TRANSMITTING DATA OF PCI BUS 



5 CROSS-REFERENCE TO RELATED APPLICATION 

This application is a continuation-in-part of prior applications Serial No. 
09/447,724, filed November 24, 1999. This application also claims the priority benefit 
of U.S.A. provisional application serial no. 60/215,565, filed on June 30, 2000, and 
Taiwan application serial no. 901 13548, filed on June 5, 2001. 

10 

BACKGROUND OF THE INVENTION 

Field of the Invention 

[0001] The invention relates in general to a PCI bus compatible structure, and 
more particularly, to a PCI bus structure that supports multiple transmission speeds. 
/ 5 Description of the Related Art 

[0002] Figure 1 shows a structure using a PCI system in a normal computer. 
The central processing unit (CPU) 10 is coupled to the PCI bus 14 via the host bridge 
12. The PCI bus 14 can be coupled to multiple masters 16a, 16b, 16c and 16d of PCI 
compatible peripherals. Each master can send a request signal (REQ) to require using 
20 the PCI bus 14. The arbiter in the host bridge 12 then sends the grant signal (GNT) to 
the master to grant the usage of the PCI bus 14. 

[0003] The data transmission between the PCI compatible peripherals (such as 
the masters or the north bridge of the computer chip set) is controlled by the following 
interface control signals. The cycle frame signal FRAME# is asserted by an initiator 
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(such as the masters or the north bridge) to confirm whether the transmission data is the 
last batch of data. When the cycle frame signal FRAME# is output, it indicates that the 
transaction of the data transmission via the PCI bus is started. As long as the cycle 
frame signal FRAME# remains in a low potential, the transaction of the data 
5 transmission continues. Meanwhile, the AD (data address signal) bus outputs a valid 
address during the address cycle and outputs a valid bus command during 
command/byte enable (CBE[3:0]) to indicate the data transaction type required by the 
initiator to a target. Right after all the valid addresses are output, the AD bus outputs 
O the data to be transmitted, which is called the data cycle. Meanwhile, the byte enable 

'S 7 0 signal of bus command after coding is output from the CBE line to transmit data. 
;fc Cessation of output of the cycle frame signal FRAME# means the transaction status is 

[% transmitting the last batch of data, or the data transmission is complete. The initiator 

n ready signal IRDY# and the target ready signal TRDY# are used to respectively indicate 

iy that the initiator and the target are ready to perform data transmission. In a read 

O 7 5 operation, the IRDY# signal means that the initiator is ready to receive data. When 
entering a write operation, the TRDY# signal indicates that the target is ready to receive 
data. The stop signal STOP# is used to indicate the target to request the initiator 
stopping the current transaction of data transmission. 

[0004] However, during transmission, all the signals are transmitted according to 
20 the 33 MHz bus clock, and are triggered according to the rising edge of the clock. Thus, 
the data signal in one clock cycle can only transmit a set of data. Therefore, the data 
transmission speed is restricted by the bus clock and cannot cope with the requirements 
of high speed of data transmission. 
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SUMMARY OF THE INVENTION 

[0005] The invention provides a bus data interface, structure and method to 
transmit data in a PCI bus. The pins of the bus request signal and bus grant signal are 
used to transmit a data strobe signal. The high potential and the low potential of the 
data strobe signal are used as a reference for transmission. Thus, the invention is 
compatible with the original PCI bus. A transmission operation having two times the 
original transmission clock is obtained to increase the overall data transmission speed. 

[0006] The bus data interface to transmit the data of the PCI bus is applied to an 
apparatus compatible with the PCI bus. The PCI bus comprises at least a bus grant 
signal and a bus grant signal. The bus data interface comprises at least a high-bit 
transmitting buffer, a low-bit transmitting buffer, a multiplexer, a strobe generator and a 
data distributor. 

[0007] The above high-bit transmitting buffer is used to receive and temporarily 
store high-bit transmitting data, while the low-bit transmitting buffer is used to receive 
and temporarily stores low-bit transmitting data. The multiplexer is coupled to the high- 
bit and the low-bit transmitting buffers to receive an internal bus clock signal of the bus 
data interface. When the internal bus clock signal is at a high potential, the multiplexer 
selects and outputs either the high-bit transmitting data or the low-bit transmitting data 
to the PCI bus. The multiplexer then selects and outputs the other of the high-bit 
transmitting data and the low-bit transmitting data to the PCI bus. 

[0008] The strobe generator uses either the bus grant signal or the bus request 
signal to generate a data strobe signal. Correspondingly, the data distributor uses either 
the bus grant signal or the bus request signal to receive the data strobe signal. When the 
bus data interface outputs data to the PCI bus, the strobe generator outputs the data 
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strobe signal in response to the internal bus clock signal. The data distributor coupled to 
the PCI bus receives data from the PCI bus according to the received data strobe signal, 
and transfers the high-bit and the low-bit data respectively. 

[0009] In one embodiment, the bus data interface to transmit data on the PCI bus 
5 shows that when the bus master supporting the dual transmission mode is writing data, 
that is, outputting data to the PCI bus, the bus request signal pin is used as the data 
transmitting strobe signal pin. When the bus master is reading data, that is, the PCI bus 
is receiving data, the bus grant signal pin is used to as the data receiving strobe signal 
pin. When applying the bus data interface to a bus bridge that arbitrates the master 

10 control of the PCI bus according to the bus request and grant signals, and when the bus 
bridge is outputting data to the PCI bus, the bus grant signal pin is the strobe signal pin 
for data transmission. Similarly, the bus request pin is the strobe signal pin for data 
receiving when the bus bridge is receiving data from the PCI bus. 

[0010] The invention provides another embodiment for the bus structure for 

7 5 transmitting data on the PCI bus. The bus grant signal pin and the bus request signal pin 
are used in the invention. The bus structure comprises at least a transmission 
compatible apparatus and reception compatible apparatus coupled to the PCI bus for 
data transmission thereon. The transmission compatible apparatus comprises at least a 
high-bit transmitting buffer, a low-bit transmitting buffer, a multiplexer, and a strobe 

20 generator. The reception compatible apparatus comprises at least a data distributor. 

[0011] The high-bit transmitting buffer is used to receive and temporarily store a 
high-bit data. Similarly, the low-bit transmitting buffer is used to receive and 
temporarily store a low-bit data. The multiplexer is coupled to the high-bit and low-bit 
transmitting buffers to receive a first internal bus clock signal. When the first internal 



FILE: 6420USF.R 1 



bus clock signal is at a high potential level, the multiplexer selects the output of either 
the high-bit or the low-bit transmitting buffer to output to the PCI bus. When the first 
internal bus clock signal is at a low potential level, the multiplexer selects the output of 
the other either the high-bit or the low-bit transmitting buffer to output to the PCI bus. 
5 When the transmission compatible apparatus outputs data to the PCI bus, the strobe 
generator generates the data strobe signal from either the bus grant signal pin or the bus 
request signal pin in response to the first internal bus clock signal. The data distributor 
of the reception compatible apparatus receives data from the PCI bus according to the 
data strobe signal, and outputs the received high-bit data and the received low-bit data, 
/ 0 respectively. 

[0012] In a further embodiment, when the transmission compatible apparatus is 
applied to the bus master and the reception compatible apparatus is applied to the bus 
bridge, the bus request signal pin transmits the data strobe signal when the bus master 
outputs data to the PCI bus. When the reception compatible apparatus is applied to the 
/ 5 bus master and the transmission compatible apparatus is applied to the bus bridge, the 
bus grant signal pin is used to receive the data strobe signal when the bus masters 
receives data from the PCI bus. The above bus bridge arbitrates the master control of 
the PCI bus according to the bus request signal and the bus grant signal. 

[0013] The invention uses data strobe signal transmitted from the bus request 
20 signal pin and the bus grant signal pin and the rising and descending edges of the data 
strobe signal as a reference for transmission. Thus, the original PCI bus is compatible, 
and the original PCI clock can be used as the strobe for an operation with a dual data 
transmission speed. 

The invention also discloses a method for transmitting data on a PCI bus in a 
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computer comprising a plurality of masters and a host bridge coupled to the PCI bus. 
The PCI bus comprises a plurality of bus request signals and a plurality of bus grant 
signals. BIOS detects whether the masters supports a dual transmission mode while 
starting up the computer. BIOS also compares the vendor's IDs and the device IDs of 
5 the masters with a status list to determine whether the masters support the dual 
transmission mode. The masters with the dual transmission mode assert the 
corresponding bus request signal to response the computer. Therefore, BIOS is capable 
of programming a host bridge in response to the masters supporting the dual 
transmission mode. When the dual transmission mode is required, a dual mode ID is 

/ 0 asserted to activate the dual transmission mode. The host bridge grants the PCI bus to 
one of the masters supporting the dual transmission mode and a dual mode ID is 
asserted. If a range of a memory space supporting the dual transmission mode is 
accessed, perform the memory access at a dual speed, otherwise perform the memory 
access at a normal speed. [0014] Both the foregoing general description and the 

7 5 following detailed description are exemplary and explanatory only and are not 
restrictive of the invention, as claimed. 



BRIEF DESCRIPTION OF THE DRAWINGS 
[0015] Figure 1 is a block diagram showing a conventional PCI bus; 
20 [0016] Figure 2 is a block diagram showing a PCI bus structure that supports a 

dual data transmission speed according to one embodiment of the invention; 

[0017] Figure 3 shows the timing sequence of a PCI bus structure that supports a 
dual data transmission speed according to one embodiment of the invention; 

[0018] Figure 4 is a block diagram showing the data distributor of a PCI bus 
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compatible apparatus with a dual transmission mode according to one embodiment of 
the invention; 

Figure 5 shows an exemplary circuit for the data distributor in Figure 4; and 
[0019] Figure 6 shows the timing sequence of the PCI bus compatible apparatus 
5 in Figure 4 and Figure 5. 

DESCRIPTION OF THE PREFERRED EMBODIMENTS 
[0020] The theory and method of the invention incorporate the major techniques 
disclosed in the Taiwanese patent application no. 88103699, with US corresponding 
10 application No. 09/447,724. The mentioned application discloses the system and 
method of data transmission on the PCI bus, and the invention further discloses the 
implemented apparatus and bus structure thereof. 

[0021] Figure 2 illustrates a block diagram showing the transmission status of a 
PCI bus structure that supports a dual transmission mode. The embodiment includes a 
15 master 54 and a host bridge 52 with a dual transmission mode function, and masters 
56/58 which are compatible with normal PCI structure. These apparatuses can be 
operated normally with the original PCI bus system. 

[0022] In Figure 2, only the PCI master 54 can support the dual transmission 
mode. In fact, the dual transmission mode is applied only when the master 54 and the 
20 host bridge 52 both with the dual transmission mode are performing write and read 
operations on AD bus. For others such as the masters 54/56/58 and the transmission 
between them, or the command output from the host bridge 52 and the transmission 
with the masters 54/56/58, the original PCI compatible control clock is used in data 
transmission to ensure the completeness of the data. 
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[0023] When the computer system is just booted, whether the host bridge 52 
comprises a dual transmission function is detected. If yes, whether the master 54, the 
master 56 and the master 58 support the dual transmission mode is judged. For 
example, the BIOS of the system itemizes all the vendor IDs and the device IDs that can 
5 support dual transmission mode as a status list. The system compares whether the 
masters 54, 56 and 58 are one of the above to support the dual transmission mode. This 
is because the specification of the standard PCI bus does not have any special ID to 
support the dual transmission mode. Alternatively, a predetermined address of a 
configured space is queried. If any of the masters supports dual transmission mode, all 

10 the master(s) supporting the dual transmission mode enable their request signals (REQ). 
The request signal(s) of all the master(s) are reported to the system via the host bridge 
52 to confirm the master(s) supporting the dual transmission mode in response to the 
request signal(s). The result is stored in the system. The BOIS, for example, programs 
the host bridge 52 according to the result, such that the host bridge 52 can distinguish 

/ 5 which request/grant signal pair supports the dual transmission mode. 

[0024] In this embodiment, as shown in Fig. 2, only the PCI master 54 can 
support the dual transmission mode. While the host bridge 52 grants the master 54 with 
the dual transmission mode and the host bridge 52 intends to operate in the dual 
transmission mode, the master 54 with the dual transmission mode asserts a plurality of 

20 distinguishable bytes at the AD bus. For example, the lowest two bits of the address 
signal[l:0] are configured as 2 to advise the host bridge 52 entering the dual 
transmission mode. When the host bridge 52 grants the master 54 with the dual 
transmission mode to use the bus, and receives the address signal of the bus command 
that has lowest two bits equal to 2, the host bridge 52 enters the dual transmission mode. 
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The BIOS informs the master 54 with the dual transmission mode about an address 
range, such as in the system memory, that supports the dual transmission mode. When 
the transaction is within the address range that supports the dual transmission mode, the 
host bridge 52 and the master 54 are both allowed to enter the dual transmission mode. 
5 In addition, the lowest two bits of the address signals[l:0] can also be configured as a 
value 0, for example, other than 2, thus the bus transactions can be configured to 
perform in a normal mode. 

[0025] In Figure 3, a timing sequence of the PCI bus structure that supports the 
dual transmission mode according to the present invention is shown. When the PCI bus 

10 starts transmitting data on the AD bus (such as the data signals 
D0/D1/D2/D3/D4/D5/D6/D7/D8/D9), the transmission strobe signal the REQ signal, is 
used to latch the data. In the data cycle, the transmission of AD bus signals D0/D1 to 
the PCI bus is started. However, the ready signal TRDY# for the selected host bridge is 
not ready yet. Thus, the master 54 resends the data D0/D1. Accordingly, by generating 

7 5 proper wait states, the transmission of data D4/D5 and D8/D9 are transferred in a 
similar way. 

[0026] The frame signal FRAME# deasserts at the last data D8/D9 to inform the 
selected host bridge that D8/D9 are the last data to be transmitted. In the second 
transmission of the data D8/D9, a stop signal STOP# is asserted to finish the 
20 transmission operation. 

[0027] In Figure 4, a block diagram of a PCI compatible apparatuswith the dual 
transmission mode according to the present invention is illustrated. The PCI bus 
structure comprises a master 54 and a host bridge both having the dual transmission 
mode. Each of the master 54 and the host bridge 52 comprises a transmission 



FILE: 6420USF.R' 



compatible apparatus and a reception compatible apparatus which both support the dual 
transmission mode. The transmission compatible apparatuses and the reception 
compatible apparatuses are correspondingly coupled to each other via the PCI bus 70. 
For example, the transmission compatible apparatus 55 of the master 54 is 
5 correspondingly connected with the reception compatible apparatus 57 via the PCI bus 
70 to write data into the memory (not shown) connected to the host bridge 52. 
Meanwhile, the bus request signal REQ is used to transmit the data strobe signal. 
Similarly, the transmission compatible apparatus (not indicated) of the host bridge 52 is 
correspondingly connected to the reception compatible apparatus (not indicated) of the 

/ 0 master 54 via the PCI bus 70. When the master 54 receives the data from the PCI bus 
70 to read the memory data via the host bridge 52, the bus grant signal GNT is asserted 
to receive the data strobe signal. 

[0028] The first-in-first-out (FIFO) memory 62 is coupled to the high-bit 
transmitting buffer ADH OUT and the low-bit transmitting buffer ADL OUT to receive a 

7 5 plurality of transmission data. FIFO 62 transfers the high-bit and low-bit data to the 
high-bit and low-bit transmitting buffers ADH OUT and ADL oux , respectively. ADL OUT 
and ADH OUT of the data buffer pair 64 respectively receive the AD bus according to the 
transmission sequence of AD bus. The received data is then transmitted as the high-bit 
transmitting data and the low-bit transmitting data to the multiplexer 66. The 

20 multiplexer 66 transmits the AD data to the PCI bus 70 according to the high potential 
level and the low potential level (or the rising and falling edges) of the bus clock signal 
PCICLK T . 

[0029] The PCI bus 70 transmits the AD bus to the data distributor 72. 
Meanwhile, the bus clock signal PCICLK T is transmitted to the data distributor 72 by 
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the strobe generator 68, which for example is a request signal apparatus 68 to utilize the 
REQ signal to generate the proper strobe signal according to the bus clock signal 
PCICLK T . That is, the transmission pin of the REQ signal is used as the pin of the data 
strobe signal to transmit the data strobe signal with the same frequency as the bus clock 
5 signal. The same frequency of the data, the data strobe signal output from the 
transmission line of the strobe generator 68 is delayed while arriving the host bridge 52. 

[0030] According to the data strobe signal coming from the strobe generator 68 
and the received bus clock signal PCICLK R , the data distributor 72 is capable of 
partitioning the received the AD bus signals. The data distributor 72 transmits the AD 

10 bus to the receiving low-bit buffer ADL in and the receiving high-bit buffer ADH in of the 
data buffer pair 74. The bus clock signal PCICLK R for the data distributor 72 is used to 
synchronize the received AD bus while transferring internally. 

[0031] Figure 5 shows a block diagram of the data distributor 72 of the PCI bus 
compatible apparatus with the dual transmission mode in Figure 4. Referring to Figures 

7 5 4 and 5, the AD bus signals received by the buffer 80 from the PCI bus 70 is output to 
an output controller 84/86. The output controllers 84 and 86 are also called the trigger 
latch 86 and the negative enable latch 84, wherein a D-type flip-flop is used as the 
output controller in this embodiment as an example. Each of the output controllers 84 
and 86 comprises a data input terminal, a trigger terminal and a data output terminal. 

20 The data input terminal is coupled to the output of the data buffer 80. The trigger 
terminal is coupled to the output of the strobe signal buffer 82 to latch the high-bit data, 
indicated as pre ADH in , and the low-bit data, indicated as pre ADL in , according to the 
received data strobe signal, which is the REQ signal in this embodiment. 

[0032] The data input terminal of the trigger latch 88 is coupled to the data 
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output terminal of the negative enable latch 84. The trigger terminal is coupled to the 
internal bus clock signal PCICLK R to cause the data of the data input terminal output to 
the data output terminal, that is, output of the received low-bit data, to be synchronous 
to the internal bus clock signal PCICLK R . Similarly, the data input terminal of the 
5 negative enable latch 90 is coupled to the data output terminal of the trigger latch 86. 
The trigger terminal of the negative enable latch 86 is coupled to the internal bus clock 
signal to cause the data of the data input terminal output at the data output terminal, that 
is, output of the received high-bit data, to be synchronous to the internal bus clock 
□ signal PCICLK R . That is, the latches 88/90 output the pre ADL in and pre ADH in signals 

% 10 according to the bus clock signal PCICLK R , so as to transfer the data to the ADL in and' 
ADH in of the data buffer pair 74 respectively. 

[0033] In Figure 5, the data input terminal of the trigger latch 88 is coupled to 
the data output terminal of the negative enable latch 84, while the data input terminal of 
the negative enable latch 90 is coupled to the data output terminal of the trigger latch 86. 
/ 5 Two sets of latches are used so as to synchronize the data with the internal bus clock 
signal PCICLK R . Therefore, one can also couple the data input terminal of the negative 
enable latch 90 to the data output terminal of the negative enable latch 84, and the data 
input terminal of the trigger latch 88 to the data output terminal of the trigger latch 86. 

[0034] Figure 6 shows the timing sequence of the PCI compatible apparatus 
20 illustrated in Figures 4 and 5. Referring to Figures 6, 5 and 4, the AD bus signals L0 
and HO, for example, are sequentially stored in the first-in-first-out memory 62, and 
respectively output to the ADL OUT and ADH OUT of the data buffer pair 64 and the 
multiplexer 66. 

[0035] The multiplexer 66 sends the AD bus signals L0 and HO to the PCI bus 
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70 according to the low and high potential levels of the bus clock signal PCICLK T . 
Meanwhile, via the strobe generator 68, the signal PCICLK T outputs the data strobe 
signal REQ OUT from the request signal pin REQ. Being delayed by the PCI bus 70, the 
PCICLK X is further sent to the data distributor 72 using the REQ IN . In Figure 6, 
according to the data strobe signal, which is generated in response to the PCICLK T 
signal, and the bus clock signal PCICLK R , the data distributor 72 outputs the AD bus 
signals L0 and HO to the ADL in and ADH in of the data buffer pair 74, respectively. The 
PCICLK T signal includes the data strobe signal in this embodiment. The rest of the AD 
bus signals are transmitted in a similar way. 

[0036] Figure 6 and Figure 5 discloses that the master 54 outputs data to the 
PCI bus by utilizing the bus request signal pin REQ transmitting the data strobe signal. 
Similarly, it can be inferred by people of ordinary skilled in the art, in view of the above 
disclosure, that applying the bus grant signal pin GNT receives the data strobe signal 
when the host bridge 52 is outputting data to the PCI bus, and the master 54 is receiving 
data on the PCI bus. 

[0037] Other embodiments of the invention will appear to those skilled in the art 
from consideration of the specification and practice of the invention disclosed herein. It 
is intended that the specification and examples be considered as exemplary only, with a 
true scope and spirit of the invention being indicated by the following claims. 
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